Self callbrating camera system

ABSTRACT

The present invention describes a system for calibrating a plurality of cameras in an area. The system method and device functions by using moving objects to calibrate, in particular using people. In addition, the system implements automatic re-calibration in a specific way to reduce human intervention, cost and time.

BACKGROUND OF THE INVENTION

This application relates to systems, methods, devices, and other techniques for video camera self-calibration based on video information received from more than one video cameras.

Methods and apparatus for calibrating cameras in the certain areas are very common. Some methods are using reference objects and manual methods to calibrate the cameras. However, these methods need human intervention and cost time and money.

Therefore, it is desirable to have systems and methods to enable self-calibration for the cameras to save time and efforts.

SUMMARY OF THE INVENTION

This application relates to systems, methods, devices, and other techniques for video camera self-calibration based on video information received from more than one video cameras. In some embodiments, the system uses people as calibration markers. Instead of finding feature matches between cameras, the system matches one or more persons between cameras. Then the system identifies certain body key points of the one or more persons and then matches these key points. In addition, the system implements automatic re-calibration in a specific way to reduce human intervention, cost and time. In some embodiments, the system extracts detections from each camera, and then synchronizes frames using time-stamp, and then clusters one or more persons using re-id features. The system then aggregates key points from one or more persons along time for each camera. The system then finds matches same time, same person key points on camera pairs and then runs un-calibrated structure from motion on the key point matches. The system then aligns and upgrades scale using one or more persons' head and feet key points or the known camera height.

In some embodiments, the system implements a self-healing scheme to recalibrate after these situations (but not limited to these situations): accidental or on purpose camera position changes, change of focus or aspect ratio, or camera upgrades.

When the system uses this self-healing scheme, the system uses multi-camera tracking to match people and key points. Then the system triangulates and projects key point coordinates. The system monitors accumulated errors over time. If the accumulated error is large, re-calibration is needed. If re-calibration is needed, the system runs people-based calibration.

In some implementations, this kind of system synchronizes system time for the plurality of cameras. Then the system detects an object moving along a route within the area and then detects feature points on the object. Then the system captures a first set of one or more images of the feature points of the object along the route by a first one of the plurality of cameras and a second set of one or more images of the feature points of the object along the route by a second one of the plurality of cameras. Time stamp is recorded for each capturing. Then the system calibrates the first one of the plurality of cameras and the second one of the plurality of cameras by matching same feature points on the object between the first set of one or more images of the object and the second set of one or more images of the object at same time stamp.

In some embodiments, the object is a person. In some embodiments, the method is conducted by a predetermined time interval. In some embodiments, the first one of the plurality of cameras and the second one of the plurality of cameras need at least 50% overlap in terms of their field of vision.

In some embodiments, the present invention describes a method for calibrating a plurality of cameras in an area. The system synchronizes system time for the plurality of cameras. The system also identifying feature points of an object moving within the area. The system also captures a first set of one or more images of the feature points during the object's movement by a first one of the plurality of cameras. The system also captures a second set of one or more images of the feature points during the object's movement by a second one of the plurality of cameras, wherein the first set of one or more images and the second set of one or more images are captured at same time, wherein time stamp is created for each capturing. The system then identifies the feature points on the object by utilizing a neural network and matches same feature points between the first set of one or more images and the second set of one or more images at same time stamp. In some embodiments, the first object is a person. In some embodiments, one of the feature points is the person's head. In some embodiments, the position information of the same feature points is X and Y coordinates within an image. In some embodiments, the object is configured to move freely.

In some embodiments, the invention is related to a system for calibrating a plurality of cameras in an area. The system comprises a controlling unit. The system also includes a first camera of the plurality of cameras coupled to the controlling unit, wherein the first camera is configured to identify one or more feature points of an object moving within the area, wherein the first camera is configured to capture a series of images of the object at a set of time slots. The system comprises a second camera of the plurality of cameras coupled to the controlling unit, wherein the second camera has same system time as in the first camera, wherein the second camera is configured to identify the one or more feature points of the object moving within the area, wherein the second camera is configured to capture another series of images of the object at the set of time slots, wherein the controlling unit calibrates the first camera and the second camera to match relative movement of the one or more feature points of the object between the series of images and the another series of images for same time slot within the set of time slots.

In some embodiment, the system comprises a storage unit coupled to the controlling unit, wherein images produced by the plurality of cameras are stored in the storage unit. In some embodiment, the system comprises a neural network coupled to the controlling unit, wherein the neural network is configured to match and identify the feature points. In some embodiments, the controlling unit tunes position and angle of the first camera and the second camera, wherein the first and the second camera has ability to pan, tilt and zoom. In some embodiments, the controlling unit sends command to the first camera and the second camera, wherein the first camera and the second camera tune themselves internally based on the commands. In some embodiments, the system re-calibrates a subset of the plurality of cameras after a time period.

In some embodiments, the system continuously monitors reprojection error of triangulated points from the first camera and the second camera, when the reprojection error consistently exceeds a certain value after some time.

These and other aspects, their implementations and other features are described in details in the drawings, the description and the claims.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 shows a method for self-calibrating a plurality of cameras in an area.

FIG. 2 shows another method for calibrating a plurality of cameras in an area.

FIG. 3 shows a third method for calibrating a plurality of cameras in an area.

FIG. 4 shows a system for calibrating a plurality of cameras in an area.

DETAILED DESCRIPTION OF THE INVENTION

FIG. 1 shows a method for self-calibrating a plurality of cameras in an area. In some implementations, the method comprises a step 105 of synchronizing system time for the plurality of cameras.

In some embodiments, the method comprises a step 110 of detecting an object moving along a route within the area.

In some embodiments, the method comprises a step 115 of detecting feature points on the object.

In some embodiments, the method comprises a step 120 of capturing a first set of one or more images of the feature points of the object along the route by a first one of the plurality of cameras and a second set of one or more images of the feature points of the object along the route by a second one of the plurality of cameras, wherein time stamp is recorded for each capturing.

In some embodiments, the method comprises a step 125 of calibrating the first one of the plurality of cameras and the second one of the plurality of cameras by matching same feature points on the object between the first set of one or more images of the object and the second set of one or more images of the object at same time stamp.

In some embodiments, the object is a person. In some embodiments, the method is conducted by a predetermined time interval. In some embodiments, the first one of the plurality of cameras and the second one of the plurality of cameras need at least 50% overlap in terms of their field of vision.

FIG. 2 shows a method for self-calibrating a plurality of cameras in an area. In some implementations, the method comprises a step 205 of synchronizing system time for the plurality of cameras.

In some embodiments, the method comprises a step 210 of detecting an object moving along a route within the area.

In some embodiments, the method comprises a step 215 of detecting feature points on the object.

In some embodiments, the method comprises a step 220 of capturing a first set of one or more images of the feature points of the object along the route by a first one of the plurality of cameras and a second set of one or more images of the feature points of the object along the route by a second one of the plurality of cameras, wherein time stamp is recorded for each capturing.

In some embodiments, the method comprises a step 222 of calculating and accumulating re-projection errors for each camera.

In some embodiments, the method comprises a step 224 of judging whether re-projection value is larger than a value.

In some embodiments, when the re-projection value is larger than the value, the method comprises a step 225 of calibrating the first one of the plurality of cameras and the second one of the plurality of cameras by matching same feature points on the object between the first set of one or more images of the object and the second set of one or more images of the object at same time stamp.

In some embodiments, when the re-projection value is not larger than the value, the method repeats from a step 205.

In some embodiments, the object is a person. In some embodiments, the method is conducted by a predetermined time interval. In some embodiments, the first one of the plurality of cameras and the second one of the plurality of cameras need at least 50% overlap in terms of their field of vision.

FIG. 3 shows another method for calibrating a plurality of cameras in an area.

In some embodiments, the method comprises a step 305 of synchronizing system time for the plurality of cameras.

In some embodiments, the method comprises a step 310 of identifying feature points of an object moving within the area.

In some embodiments, the method comprises a step 315 of capturing a first set of one or more images of the feature points during the object's movement by a first one of the plurality of cameras.

In some embodiments, the method comprises a step 320 of capturing a second set of one or more images of the feature points during the object's movement by a second one of the plurality of cameras, wherein the first set of one or more images and the second set of one or more images are captured at same time, wherein time stamp is created for each capturing.

In some embodiments, the method comprises a step 325 of identifying the feature points on the object by utilizing a neural network.

In some embodiments, the method comprises a step 328 of generating identifying signatures for each object of the objects by utilizing another neural network.

In some embodiments, the method comprises a step 330 of matching same feature points between the first set of one or more images and the second set of one or more images at same time stamp.

In some embodiments, the first object is a person. In some embodiments, one of the feature points is the person's head. In some embodiments, the position information of the same feature points is X and Y coordinates within an image. In some embodiments, the object is configured to move freely.

FIG. 4 shows a system for calibrating a plurality of cameras in an area.

In some embodiment, the system 405 comprises a storage unit 450 coupled to a controlling unit 410, wherein images produced by the plurality of cameras are stored in the storage unit.

In some embodiment, a first camera 415 of the plurality of cameras is coupled to the controlling unit 410, wherein the first camera 415 is configured to identify one or more feature points of an object moving within the area, wherein the first camera 415 is configured to capture a series of images of the object at a set of time slots.

In some embodiment, a second camera 420 of the plurality of cameras is coupled to the controlling unit 410, wherein the second camera 420 has same system time as in the first camera 415, wherein the second camera 420 is configured to identify the one or more feature points of the object moving within the area, wherein the second camera 420 is configured to capture another series of images of the object at the set of time slots, wherein the controlling unit 310 calibrates the first camera 415 and the second camera 420 to match relative movement of the one or more feature points of the object between the series of images and the another series of images for same time slot within the set of time slots.

In some embodiment, the system comprises a neural network 435 coupled to the controlling unit 410, wherein the neural network 435 is configured to match and identify the feature points. In some embodiments, the controlling unit 410 tunes position and angle of the first camera 415 and the second camera 420, wherein the first and the second camera has ability to pan, tilt and zoom. In some embodiments, the controlling unit 410 sends command to the first camera 415 and the second camera 420, wherein the first camera 415 and the second camera 420 tunes themselves internally based on the commands. In some embodiments, the system re-calibrates a subset of the plurality of cameras after a time period.

In some embodiments, the system continuously monitors reprojection error of triangulated points from the first camera 415 and the second camera 420, wherein the system initiates a recalibration when the re-projection error exceeds a certain value.

In some embodiment, the system comprises another neural network 450 coupled to the controlling unit 410, wherein the neural network 450 is configured to identify signatures of each object within the objects. 

The invention claimed is:
 1. A method for calibrating a plurality of cameras in an area, comprising: Synchronizing system time for the plurality of cameras; Detecting an object moving along a route within the area; Detecting feature points on the object; Capturing a first set of one or more images of the feature points of the object along the route by a first one of the plurality of cameras and a second set of one or more images of the feature points of the object along the route by a second one of the plurality of cameras, wherein time stamp is recorded for each capturing; and Calibrating the first one of the plurality of cameras and the second one of the plurality of cameras by matching same feature points on the object between the first set of one or more images of the object and the second set of one or more images of the object at same time stamp.
 2. The method for calibrating a plurality of cameras in an area of claim 1, wherein the object is a person.
 3. The method for calibrating a plurality of cameras in an area of claim 1, wherein the method is conducted by a predetermined time interval.
 4. The method for calibrating a plurality of cameras in an area of claim 1, wherein the first one of the plurality of cameras and the second one of the plurality of cameras need at least 50% overlap in terms of their field of vision.
 5. A method for calibrating a plurality of cameras in an area, comprising: Synchronizing system time for the plurality of cameras; Identifying feature points of an object moving within the area; Capturing a first set of one or more images of the feature points during the object's movement by a first one of the plurality of cameras; Capturing a second set of one or more images of the feature points during the object's movement by a second one of the plurality of cameras, wherein the first set of one or more images and the second set of one or more images are captured at same time, wherein time stamp is created for each capturing; Identifying the feature points on the object by utilizing a neural network; and Matching same feature points between the first set of one or more images and the second set of one or more images at same time stamp.
 6. A method for calibrating a plurality of cameras in an area of claim 5, wherein the first object is a person.
 7. A method for calibrating a plurality of cameras in an area of claim 6, wherein one of the feature points is the person's head.
 8. A method for calibrating a plurality of cameras in an area of claim 5, wherein the position information of the same feature points is X and Y coordinates within a image.
 9. A method for calibrating a plurality of cameras in an area of claim 5, wherein the object is configured to move freely.
 10. A system for calibrating a plurality of cameras in an area, comprising: A controlling unit; A first camera of the plurality of cameras coupled to the controlling unit, wherein the first camera is configured to identify one or more feature points of an object moving within the area, wherein the first camera is configured to capture a series of images of the object at a set of time slots; and A second camera of the plurality of cameras coupled to the controlling unit, wherein the second camera has same system time as in the first camera, wherein the second camera is configured to identify the one or more feature points of the object moving within the area, wherein the second camera is configured to capture another series of images of the object at the set of time slots, wherein the controlling unit calibrates the first camera and the second camera to match relative movement of the one or more feature points of the object between the series of images and the another series of images for same time slot within the set of time slots.
 11. The system for calibrating a plurality of cameras in an area of claim 10, further comprising: A storage unit coupled to the controlling unit, wherein images produced by the plurality of cameras are stored in the storage unit.
 12. The system for calibrating a plurality of cameras in an area of claim 10, further comprising: A neural network coupled to the controlling unit, wherein the neural network is configured to match and identify the feature points.
 13. The system for calibrating a plurality of cameras in an area of claim 10, wherein the controlling unit tunes position and angle of the first camera and the second camera, wherein the first and the second camera has ability to pan, tilt and zoom.
 14. The system for calibrating a plurality of cameras in an area of claim 10, wherein the controlling unit sends command to the first camera and the second camera, wherein the first camera and the second camera tunes themselves internally based on the commands.
 15. The system for calibrating a plurality of cameras in an area of claim 10, wherein the system re-calibrates a subset of the plurality of cameras after a time period.
 16. The system for calibrating a plurality of cameras in an area of claim 10, wherein The system continuously monitors re-projection error of triangulated points from the first camera and the second camera, wherein the system initiates a recalibration when the re-projection error exceeds a certain value. 